﻿Imports System.Data
Imports VSModel
Imports Cls_Common
Imports SecurityService
Partial Class Control_CertifiedHousehold_Edit
    Inherits System.Web.UI.UserControl
    Dim itm As New ListItem("--- Chọn ---", "")
    Private Shared ReadOnly log As log4net.ILog = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType)
#Region "Event for control "
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
        If Not IsPostBack Then
            If Not Request.QueryString("CertifiedID").ToString.Equals("0") Then
                hidID.Value = Request.QueryString("CertifiedID")
                Load2Grid()
            End If
        End If
    End Sub
    Protected Sub Load2Grid()
        Using _data As New VSEntities
            'provinces all
            Dim _jp = (From q In _data.Provinces Order By q.Title Select q.Id, q.Code, q.Title).ToList
            'đia điểm
            Dim TinhDiaDiemKD = (From q In _data.Provinces Where q.ParentId = 0 Order By q.Title Select q.Id, q.Code, q.Title).ToList
            With ddlTinhDiaDiemKD
                .DataSource = TinhDiaDiemKD
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlHuyenDiaDiemKD
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlXaThiTranDiaDiemKD
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            'thuong tru
            Dim TinhHoKhau = (From q In _data.Provinces Where q.ParentId = 0 Order By q.Title Select q.Id, q.Code, q.Title).ToList
            With ddlTinhHoKhau
                .DataSource = TinhHoKhau
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlHuyenHoKhau
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlXaThiTranHoKhau
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            'tam tru
            Dim TinhHienTai = (From q In _data.Provinces Where q.ParentId = 0 Order By q.Title Select q.Id, q.Code, q.Title).ToList
            With ddlTinhHienTai
                .DataSource = TinhHienTai
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlHuyenHienTai
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            With ddlXaThiTranHienTai
                .DataSource = _jp
                .DataValueField = "Id"
                .DataTextField = "Title"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            'NGanh nghe
            Dim linhvuc = (From q In _data.BusinessFields Order By q.Name Select New With {.Id = q.Id, .Name = q.Name}).ToList
            With ddlBusinessField
                .DataSource = linhvuc
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            ''dan toc
            Dim dantoc = (From q In _data.Citizens Order By q.Name Select New With {.Id = q.Name, .Name = q.Name}).ToList
            With ddlCitizen
                .DataSource = dantoc
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            'quoc gia
            Dim Country = (From q In _data.Countries Order By q.Name Select New With {.Id = q.Name, .Name = q.Name}).ToList
            With ddlCountry
                .DataSource = Country
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            'dong vi cap giay chung nhan CMND
            Dim DeptCertified = (From q In _data.DeptIdentifies Order By q.Name Select New With {.Id = q.Name, .Name = q.Name}).ToList
            With ddlDeptCertified
                .DataSource = DeptCertified
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            ' 'don vi cap giay khac
            Dim d = (From q In _data.DeptIdentifies Order By q.Name Select New With {.Id = q.Id, .Name = q.Name}).ToList
            With ddlOthersPaper_NoiCap
                .DataSource = d
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With

            'giấy tờ khác
            Dim CertifiedPaperDict = (From q In _data.CertifiedPaperDicts Order By q.Name Select New With {.Id = q.Id, .Name = q.Name}).ToList
            With ddlOthersPaper
                .DataSource = CertifiedPaperDict
                .DataValueField = "Id"
                .DataTextField = "Name"
                .DataBind()
                .Items.Add(New ListItem("--- Chọn ---", 0))
                .SelectedValue = 0
            End With
            'thanh phan ho so
            Dim lstThanhPhanHoSo = (From q In _data.ThanhPhanHoSoes Order By q.IsDefault Descending, q.TenHoSo Select q).ToList
            Dim strKey_Name() As String = {"Id", "MaHoSo", "IsDefault"}
            With grdShow
                .DataKeyNames = strKey_Name
                .DataSource = lstThanhPhanHoSo
                .DataBind()
            End With

            Dim p = (From q In _data.CertifiedHouseholds Where q.CertifiedID = hidID.Value Select q).FirstOrDefault

            If Not p Is Nothing Then
                'thong tin ca nhan
                txtOwRepresentative.Text = IIf(IsNothing(p.Ow_Name) = True, "", p.Ow_Name) 'Họ tên
                rdlSex.SelectedValue = IIf(IsNothing(p.Ow_Sex) = True, "", p.Ow_Sex) 'giới tính
                txtOwDateOfBirth.Text = IIf(IsNothing(p.Ow_BirthDate) = True, "", p.Ow_BirthDate) 'ngày tháng năm sinh

                'dân tộc
                'trường hợp dữ liệu inport vào trường dân tộc là chuỗi
                Dim National = p.Ow_National_ID
                If IsNumeric(National) Then 'kiểm tra number hay string
                    If Not p.Ow_National_ID Is Nothing AndAlso p.Ow_National_ID <> "" Then
                        ddlCitizen.SelectedValue = p.Ow_National_ID
                    End If

                Else
                    Dim _joinNational = (From k In _data.Citizens Where k.Name = National Select k).FirstOrDefault
                    ddlCitizen.SelectedValue = _joinNational.Name
                End If

                'Quốc tịch
                'trường hợp dữ liệu inport vào trường Quốc tịch là chuỗi
                Dim Nationality = p.Ow_Nationality_ID
                If IsNumeric(Nationality) Then 'kiểm tra number hay string
                    If Not p.Ow_Nationality_ID Is Nothing AndAlso p.Ow_Nationality_ID <> "" Then
                        ddlCountry.SelectedValue = p.Ow_Nationality_ID
                    End If
                Else
                    Dim _joinNationality = (From k In _data.Countries Where k.Name = Nationality Select k).FirstOrDefault
                    ddlCountry.SelectedValue = _joinNationality.Name
                End If

                txtOwCardId.Text = IIf(IsNothing(p.Ow_CardID) = True, "", p.Ow_CardID) 'Số CMND
                If Not p.Ow_CardDate Is Nothing Then
                    txtOwCardDate.Text = CType(p.Ow_CardDate, Date).ToString("dd/MM/yyyy") 'Ngày cấp
                End If
                'Nơi cấp
                'Quốc tịch
                'trường hợp dữ liệu inport là chuỗi
                Dim DeptId = p.Ow_Provider_ID
                If IsNumeric(DeptId) Then 'kiểm tra number hay string
                    If Not p.Ow_Provider_ID Is Nothing AndAlso p.Ow_Provider_ID <> "" Then
                        ddlDeptCertified.SelectedValue = p.Ow_Provider_ID
                    End If
                Else
                    Dim _joinDeptCertified = (From k In _data.DeptIdentifies Where k.Name = DeptId Select k).FirstOrDefault
                    ddlDeptCertified.SelectedValue = _joinDeptCertified.Name
                End If
                'giay to khac
                If Not p.Ow_Doc_ID Is Nothing AndAlso p.Ow_Doc_ID <> "" Then
                    ddlOthersPaper.SelectedValue = p.Ow_Doc_ID 'Giấy tờ khác
                Else
                    ddlOthersPaper.Items.Clear()

                End If

                txtOtherPaperCode.Text = IIf(IsNothing(p.Ow_DocCode) = True, "", p.Ow_DocCode) 'Mã số

                If Not p.Ow_DocDate Is Nothing AndAlso p.Ow_DocDate <> "01/01/1900" Then
                    txtOthersPaperDateIssue.Text = CType(p.Ow_DocDate, Date).ToString("dd/MM/yyyy") 'Ngày cấp
                End If

                If Not p.Ow_DocOffiCertifiedID Is Nothing AndAlso p.Ow_DocOffiCertifiedID <> "" Then
                    ddlOthersPaper_NoiCap.SelectedValue = p.Ow_DocOffiCertifiedID 'Nơi cấp
                Else
                    ddlOthersPaper_NoiCap.Items.Clear()
                End If


                ''Thông tin hộ kinh doanh: 
                txtBizName.Text = IIf(IsNothing(p.Biz_VietName) = True, "", p.Biz_VietName) 'Tên hộ kinh doanh
                txtOw_Tel.Text = IIf(IsNothing(p.Ow_Tel) = True, "", p.Ow_Tel) 'điện thoai
                txtOw_Fax.Text = IIf(IsNothing(p.Ow_Fax) = True, "", p.Ow_Fax) 'fax
                txtOw_Email.Text = IIf(IsNothing(p.Ow_Email) = True, "", p.Ow_Email) 'Email
                txtOw_WebSite.Text = IIf(IsNothing(p.Ow_WebSite) = True, "", p.Ow_WebSite) 'Website
                'nganh nghe kinh doanh và linh vưc
                ' p.NganhNgheKinhDoanh = ddlNganhNgheKinhDoanh.SelectedValue 'ngành nghề kinh doanh
                If Not p.LinhVucKinhDoanh Is Nothing AndAlso p.LinhVucKinhDoanh <> "" Then
                    ddlBusinessField.SelectedValue = p.LinhVucKinhDoanh 'Lĩnh vực kinh doanh
                End If


                txtBiz_InvestCapital.Text = IIf(IsNothing(p.Biz_InvestCapital) = True, "", p.Biz_InvestCapital)  'vốn kinh doanh
                txtBiz_WordsMoney.Text = IIf(IsNothing(p.Biz_WordsMoney) = True, "", p.Biz_WordsMoney) 'Tiền viết bằng chữ
                txtMoney_string.Text = IIf(IsNothing(p.Biz_WordsMoney) = True, "", p.Biz_WordsMoney)
                'Địa chỉ phường xa huyên
                'thuong trú
                Dim _jth = (From q In _data.CertifiedHouseholdAddresses Where q.CertifiedID = hidID.Value And q.TypeId = LoaiDiaChi.ThuongTru Select q).FirstOrDefault
                If Not _jth Is Nothing Then
                    txtDiaChiHoKhau.Text = _jth.Adress
                    ddlTinhHoKhau.SelectedValue = _jth.TinhId
                    ddlHuyenHoKhau.SelectedValue = _jth.HuyenId
                    hidHuyenHoKhau.Text = _jth.HuyenId
                    ddlXaThiTranHoKhau.SelectedValue = _jth.XaThiTranId
                    hidXaThiTranHoKhau.Text = _jth.XaThiTranId
                End If
                'tam trú
                Dim _jtr = (From q In _data.CertifiedHouseholdAddresses Where q.CertifiedID = hidID.Value And q.TypeId = LoaiDiaChi.TamTru Select q).FirstOrDefault
                If Not _jtr Is Nothing Then
                    txtDiaChiHienTai.Text = _jtr.Adress
                    ddlTinhHienTai.SelectedValue = _jtr.TinhId
                    ddlHuyenHienTai.SelectedValue = _jtr.HuyenId
                    hidHuyenHienTai.Text = _jtr.HuyenId
                    ddlXaThiTranHienTai.SelectedValue = _jtr.XaThiTranId
                    hidXaThiTranHienTai.Text = _jtr.XaThiTranId
                End If
                'đia điểm kinh doanh
                Dim _jdd = (From q In _data.CertifiedHouseholdAddresses Where q.CertifiedID = hidID.Value And q.TypeId = LoaiDiaChi.DiaDiemKinhDoanh Select q).FirstOrDefault
                If Not _jdd Is Nothing Then
                    txtBiz_HeadOffice.Text = _jdd.Adress
                    ddlTinhDiaDiemKD.SelectedValue = _jdd.TinhId
                    ddlHuyenDiaDiemKD.SelectedValue = _jdd.HuyenId
                    hidHuyenDiaDiemKD.Text = _jdd.HuyenId
                    ddlXaThiTranDiaDiemKD.SelectedValue = _jdd.XaThiTranId
                    hidXaThiTranDiaDiemKD.Text = _jdd.XaThiTranId
                End If
            End If
        End Using
    End Sub
    Protected Sub btnSave_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnSave.Click
        Using data As New VSEntities
            Dim checkCode = (From q In data.CertifiedHouseholds Where q.Biz_VietName = txtBizName.Text.Trim() And q.CertifiedID <> hidID.Value Select q).FirstOrDefault
            If checkCode Is Nothing Then
                Dim p = (From q In data.CertifiedHouseholds Where q.CertifiedID = hidID.Value Select q).FirstOrDefault
                If Not p Is Nothing Then
                    Try
                        'Thông tin chung
                        p.CertifiedStatus = "M" 'cấp mới
                        p.CertifiedUp_Time = 0 'cap moi
                        p.CertifiedUp_Date = Now 'ngay nhap ho so
                        'thong tin ca nhan
                        p.Ow_Name = txtOwRepresentative.Text 'Họ tên
                        p.Ow_Sex = rdlSex.SelectedValue 'giới tính
                        p.Ow_BirthDate = txtOwDateOfBirth.Text 'ngày tháng năm sinh
                        p.Ow_National_ID = ddlCitizen.Text 'dân tộc
                        p.Ow_Nationality_ID = ddlCountry.Text 'Quốc tịch


                        p.Ow_CardID = txtOwCardId.Text 'Số CMND
                        p.Ow_CardDate = StringToDate(txtOwCardDate.Text) 'Ngày cấp
                        p.Ow_Provider_ID = ddlDeptCertified.Text 'Nơi cấp

                        'giay to khac
                        p.Ow_Doc_ID = ddlOthersPaper.SelectedValue 'Giấy tờ khác
                        p.Ow_DocCode = txtOtherPaperCode.Text 'Mã số
                        p.Ow_DocDate = StringToDate(txtOthersPaperDateIssue.Text.Trim()) 'Ngày cấp

                        p.Ow_DocOffiCertifiedID = ddlOthersPaper_NoiCap.SelectedValue 'Nơi cấp

                        'Thông tin hộ kinh doanh: 
                        p.Biz_VietName = txtBizName.Text.Trim() 'Tên hộ kinh doanh
                        p.Ow_Tel = txtOw_Tel.Text.Trim() 'điện thoai
                        p.Ow_Fax = txtOw_Fax.Text.Trim() 'fax
                        p.Ow_Email = txtOw_Email.Text.Trim() 'Email
                        p.Ow_WebSite = txtOw_WebSite.Text.Trim() 'Website
                        'nganh nghe kinh doanh và linh vưc
                        ' p.NganhNgheKinhDoanh = ddlNganhNgheKinhDoanh.SelectedValue 'ngành nghề kinh doanh
                        p.LinhVucKinhDoanh = ddlBusinessField.Text 'Lĩnh vực kinh doanh
                        p.Biz_InvestCapital = txtBiz_InvestCapital.Text.Trim() 'vốn kinh doanh
                        p.Biz_WordsMoney = txtMoney_string.Text.Trim() 'Tiền viết bằng chữ

                        p.Modified = Now
                        p.Modifier = Session("UserName")
                        'p.StatusId = TinhTrangHoSo.Nhap ' một cửa sửa tình trạng nào vẫn nằm tình trạng đó
                        'p.NguonTao = NguonTao.MotCua 'khi edit thi ko can vi nguon tao la luc tao
                        ' p.ProvinceId = hidHuyenDiaDiemKD.Text ' Huyên đang ký kinh doanh, vi huyen la minh xac dinh luc tao
                        data.SaveChanges()
                        'Địa chỉ phường xa huyên
                        'lay thanh phan ho so , xoa phan cu truoc
                        Dim _jtr = (From q In data.CertifiedHouseholdAddresses Where q.CertifiedID = hidID.Value Select q).ToList
                        For Each a In _jtr
                            data.CertifiedHouseholdAddresses.DeleteObject(a)
                        Next
                        data.SaveChanges()
                        Dim tht As New VSModel.CertifiedHouseholdAddress
                        'thường trú
                        tht.CertifiedID = p.CertifiedID
                        tht.TypeId = LoaiDiaChi.ThuongTru
                        tht.Adress = txtDiaChiHoKhau.Text.Trim()
                        tht.TinhId = ddlTinhHoKhau.SelectedValue
                        'khi set = javascript se ko lay dc  phai set vao hidden field
                        tht.HuyenId = hidHuyenHoKhau.Text
                        tht.XaThiTranId = hidXaThiTranHoKhau.Text
                        data.CertifiedHouseholdAddresses.AddObject(tht)
                        data.SaveChanges()
                        'luu thuong tru vao CertifiedHousehold
                        'lay tien cac truong theo value
                        'xa
                        Dim jx = (From q In data.Provinces Where q.Id = hidXaThiTranHoKhau.Text Select q.Title).FirstOrDefault
                        'huyen
                        Dim jh = (From q In data.Provinces Where q.Id = hidHuyenHoKhau.Text Select q.Title).FirstOrDefault
                        'tinh
                        Dim jt = (From q In data.Provinces Where q.Id = ddlTinhHoKhau.SelectedValue Select q.Title).FirstOrDefault
                        p.Ow_Resident = txtDiaChiHoKhau.Text.Trim() & "," & jx & "," & jh & "," & jt
                        data.SaveChanges()
                        'tam trú
                        Dim tt As New VSModel.CertifiedHouseholdAddress
                        tt.CertifiedID = p.CertifiedID
                        tt.TypeId = LoaiDiaChi.TamTru
                        tt.Adress = txtDiaChiHienTai.Text.Trim()
                        tt.TinhId = ddlTinhHienTai.SelectedValue
                        'khi set = javascript se ko lay dc  phai set vao hidden field
                        tt.HuyenId = hidHuyenHienTai.Text
                        tt.XaThiTranId = hidXaThiTranHienTai.Text
                        data.CertifiedHouseholdAddresses.AddObject(tt)
                        data.SaveChanges()
                        'luu tam tru vao certifiedhousehold
                        'lay tien cac truong theo value
                        'xa
                        Dim jxt = (From q In data.Provinces Where q.Id = hidXaThiTranHienTai.Text Select q.Title).FirstOrDefault
                        'huyen
                        Dim jht = (From q In data.Provinces Where q.Id = hidHuyenHienTai.Text Select q.Title).FirstOrDefault
                        'tinh
                        Dim jtt = (From q In data.Provinces Where q.Id = ddlTinhHienTai.SelectedValue Select q.Title).FirstOrDefault
                        p.Ow_Present = txtDiaChiHienTai.Text.Trim() & "," & jxt & "," & jht & "," & jtt
                        data.SaveChanges()
                        'địa điểm kinh doanh
                        Dim kd As New VSModel.CertifiedHouseholdAddress
                        kd.CertifiedID = p.CertifiedID
                        kd.TypeId = LoaiDiaChi.DiaDiemKinhDoanh
                        kd.Adress = txtBiz_HeadOffice.Text.Trim()
                        kd.TinhId = ddlTinhDiaDiemKD.SelectedValue
                        'khi set = javascript se ko lay dc  phai set vao hidden field
                        kd.HuyenId = hidHuyenDiaDiemKD.Text
                        kd.XaThiTranId = hidXaThiTranDiaDiemKD.Text
                        data.CertifiedHouseholdAddresses.AddObject(kd)
                        data.SaveChanges()
                        'luu dia diem kinh doanh vao certifiedhousehold
                        'lay tien cac truong theo value
                        'xa
                        Dim jxd = (From q In data.Provinces Where q.Id = hidXaThiTranDiaDiemKD.Text Select q.Title).FirstOrDefault
                        'huyen
                        Dim jhd = (From q In data.Provinces Where q.Id = hidHuyenDiaDiemKD.Text Select q.Title).FirstOrDefault
                        'tinh
                        Dim jtd = (From q In data.Provinces Where q.Id = ddlTinhDiaDiemKD.SelectedValue Select q.Title).FirstOrDefault
                        p.Biz_HeadOffice = txtBiz_HeadOffice.Text.Trim() & "," & jxd & "," & jhd & "," & jtd
                        data.SaveChanges()
                        'start ngành nghề

                        'xoa thong tin nganh nghe ttuoc khi luu
                        Dim _jng = (From q In data.CertifiedHouseholdNganhNghes Where q.CertifiedID = hidID.Value Select q).ToList
                        For Each _i In _jng
                            data.CertifiedHouseholdNganhNghes.DeleteObject(_i)
                        Next
                        data.SaveChanges()
                        'lưu thông tin cho CertifiedHouseholdNganhNghe
                        Try
                            Dim index As Integer = 0
                            Dim GrossAmount As Integer = 0
                            For i As Integer = 0 To hidRowIndex.Value - 1
                                Dim strMaterialCode As String = ""
                                Dim strMaterialDescription As String = ""
                                Dim strUnit As String = ""
                                Dim intAmount As Integer = 0

                                Dim txtMaterialCode As String = "txtChoice" + i.ToString
                                If Request.Form(txtMaterialCode) <> Nothing AndAlso Request.Form(txtMaterialCode).ToString.Trim() <> "" Then
                                    strMaterialCode = Request.Form(txtMaterialCode)
                                End If

                                Dim txtMaterialDescription As String = "txtDescription" + i.ToString
                                If Request.Form(txtMaterialDescription) <> Nothing AndAlso Request.Form(txtMaterialDescription).ToString.Trim() <> "" Then
                                    strMaterialDescription = Request.Form(txtMaterialDescription)
                                End If

                                If (strMaterialCode.Trim <> "") Then
                                    Dim _NganhNgheId As Integer = (From q In data.DanhMucNganhNghes Where q.Code = strMaterialCode Select q.Id).FirstOrDefault

                                    Dim NganhNgheList As New CertifiedHouseholdNganhNghe
                                    NganhNgheList.CertifiedID = p.CertifiedID
                                    NganhNgheList.DanhMucNganhNgheID = _NganhNgheId
                                    NganhNgheList.Description = strMaterialDescription

                                    data.CertifiedHouseholdNganhNghes.AddObject(NganhNgheList)

                                    data.SaveChanges()
                                    index = index + 1

                                    'End If
                                End If
                            Next
                        Catch ex As Exception
                            Excute_Javascript("Alertbox('Cập nhật ngành nghề thất bại.');", Me.Page, True)
                            Exit Sub
                        End Try
                        'end ngành nghề

                        'xoa tphan ho so


                        'lay thanh phan ho so , xoa phan cu truoc
                        Dim _tphs = (From q In data.CertifiedHouseholdThanhPhanHoSoes Where q.CertifiedID = hidID.Value Select q).ToList
                        For Each a In _tphs
                            data.CertifiedHouseholdThanhPhanHoSoes.DeleteObject(a)
                        Next
                        data.SaveChanges()

                        'start thành phần hồ sơ
                        Dim intId As Integer = 0
                        For Each item As GridViewRow In grdShow.Rows
                            Dim chkItem As New CheckBox
                            chkItem = CType(item.FindControl("chkItem"), CheckBox)
                            If chkItem.Checked Then
                                'lay id cua thanh phan ho so
                                intId = grdShow.DataKeys(item.RowIndex)("Id").ToString
                                Dim ThanhPhanHoSo As New CertifiedHouseholdThanhPhanHoSo
                                ThanhPhanHoSo.CertifiedID = p.CertifiedID
                                ThanhPhanHoSo.ThanhPhanHoSoId = intId
                                data.CertifiedHouseholdThanhPhanHoSoes.AddObject(ThanhPhanHoSo)
                                data.SaveChanges()
                            End If
                        Next

                        Insert_App_Log("Edit CertifiedHousehold:" & txtOwRepresentative.Text.Trim & "", Function_Name.CertifiedHousehold, Audit_Type.Create, Request.ServerVariables("REMOTE_ADDR"), Session("UserName"))
                        Excute_Javascript("Alertbox('Thêm mới dữ liệu thành công.');window.location ='../../Page/TiepNhan/List.aspx?Certifiedid=" & Request("Certifiedid") & "';", Me.Page, True)

                        'Excute_Javascript("alert('Cập nhật dữ liệu thành công.');window.location ='../../Page/Store/List.aspx';", Me.Page, True)

                    Catch ex As Exception
                        log4net.Config.XmlConfigurator.Configure()
                        log.Error("Error error " & AddTabSpace(1) & Session("Username") & AddTabSpace(1) & "IP:" & GetIPAddress(), ex)
                        Excute_Javascript("Alertbox('Cập nhật thất bại.');window.location ='../../Page/TiepNhan/List.aspx';", Me.Page, True)
                    End Try
                End If
            Else
                Excute_Javascript("Alertbox('Mã đã tồn tại trong hệ thống.')", Me.Page, True)
            End If
        End Using
    End Sub

    Protected Sub btnHuy_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnHuy.Click
        Response.Redirect(MainDomain & "myAdmin.html")
    End Sub
    Protected Sub grdShow_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles grdShow.RowDataBound

        Using _data As New VSEntities
            If e.Row.RowIndex >= 0 Then
                Dim lblSTT As Label = CType(e.Row.FindControl("lblSTT"), Label)
                lblSTT.Text = e.Row.RowIndex + 1
                'lay thanh phan ho so 
                Dim _j = (From q In _data.CertifiedHouseholdThanhPhanHoSoes Where q.CertifiedID = hidID.Value Select q.ThanhPhanHoSoId).ToArray
                If Not _j Is Nothing Then
                    Dim chkItem As CheckBox = e.Row.FindControl("chkItem")
                    'kiem tra id cua item co trong tphoso hay ko? neu co thi check ko thi uncheck
                    Dim curId As Integer = grdShow.DataKeys(e.Row.RowIndex)("Id")
                    If Not grdShow.DataKeys(e.Row.RowIndex)("Id") Is Nothing AndAlso _j.Contains(curId) Then
                        chkItem.Checked = 1
                    End If

                End If
            End If
        End Using
    End Sub
#End Region
End Class
